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TITLE OF THE INVENTION 
ATM COMMUNICATION APPARATUS AND 
ATM CELL FORWARDING CONTROL METHOD 

5 BACKGROUND OF THE INVENTION 

(1) Field of the Invention 

The present invention relates to an ATM (Asynchronous 
Transfer Mode) communication apparatus and an ATM cell 
forwarding control method and, more particularly, to an ATM 
10 communication apparatus having the function of avoiding 
occurrence of congestion in an ATM network and an ATM cell 
forwarding control method for avoiding occurrence of 
conges tion . 

(2) Description of the Related Art 

15 As a personal computer is widely spreading and the use 

of the Internet is increasing in recent years, in an access 
network, bursty data traffic is increasing other than voice 
and image traffics. In consideration of future trends in 
access networks, as service classes aiming at avoiding a 

20 congestion state which can occur in an access network where 
traffic is heavy and at efficiently accommodating traffic, 
the ATM forum and ITU (International Telecommunication Union) 
propose ABR (Available Bit Rate) and GFR (Guaranteed Frame 
Rate) . 

25 In the ABR service, each of user terminals determines 
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an ACR (Allowed Cell Rate) which can be used each time in 
accordance with the state of a network by setting a PGR (Peak 
Cell Rate) as the upper limit of a cell transmission rate and 
an MCR (Minimum Cell Rate) as the lower limit. A data source 
5 end system searches for an ACR of itself from RM cells inserted 
to a data cell train at predetermined intervals (or 
predetermined frequency according to a bandwidth used) . In 
each of the RM cells, the value of the PCR of the source end 
system is set as an explicit cell rate (ER) . Each of nodes 

10 on an ABR connection can revise the value in the ER field in 
a received RM cell downward to a cell rate which can be supported 
by the node. At a node where congestion occurs, by setting 
an explicit forward congestion indication (EFCI) bit of a 
passing data cell to "1", the occurrence of the congestion 

15 can be notified to a destination end system. 

The destination end system receives an RM cell and returns 
it to the source end system. In the case where the occurrence 
of the congestion in the network was notified by the explicit 
forward congestion indication (EFCI) bit in the data cell, 

20 the destination end system rewrites the congestion indication 
(CI) bit in the RM cell to be returned to the source end system 
to "1". When there is no special change in the contents of 
the returned RM cell, the source end system increases the value 
of the ACR at a predetermined rate, thereby gradually bringing 

25 the transmission cell rate to the PCR. On the contrary, when 
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the congestion indication (CI) bit in the received RM cell 
is "1", the ACR is decreased at a predetermined rate (1/RDF: 
Rate Decrease Factor) . If the value of the ER set by the source 
end system has been rewritten to a lower value, by decreasing 
5 the allowed cell rate (ACR) to the value designated by the 
ER, a break from the congestion state is attempted. 

On the other hand, in order to efficiently accommodate 
the traffic, GFR guarantees the minimum cell rate for each 
of connections. When an unused bandwidth exists in a 

10 transmission line , GFR allows the unusedbandwidth to be equally 
shared by a plurality of connections multiplexed on the 
transmission line. In the case where an ATM cell is discarded 
at the time of congestion, in the GFR service, it is proposed 
to discard the cells on a packet unit basis by expecting a 

15 data retransmitting function of an upper layer in communication 
between terminals, such as the TCP/IP (Transmission Control 
Protocol/Internet Protocol). 



SUMMARY OF THE INVENTION 

20 The GFR service realizes communications effectively 

using an unused bandwidth in a transmission line within the 
range of the peak cell rate of each of connections. In the 
GFR service, however, the transmission rate of each of the 
connections depends on the traffic volume on the transmission 

25 line. When the traffic increases and the unused bandwidth 
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decreases, a problem such that the transfer rate of each 
connection decreases close to the minimum cell rate arises. 
Consequently , for example , when a source end terminal transmits 
ATM cells at a rate close to the peak cell rate, if the 
5 transmission line is unoccupied, high-speed data transfer 
effectively utilizing the unused bandwidth can be performed. 
When the traffic volume increases and the transfer rate which 
can be allocated to each of the connections decreases , however , 
the amount of cells stored in the ATM node increases and a 

10 connection which enters a congested state occurs. 

The conventional GFR service takes a negative measure 
such that when congestion occurs, apacket which becomes invalid 
due to discarding a cell thereof is recovered by retransmission 
from the source end terminal. A control of a cell amount 

15 transmitted from a terminal in accordance with the traffic 
volume to prevent occurrence of congestion is not performed. 
In the ABR service, the allowed cell rate (transmission cell 
amount) of the source end terminal is controlled at a time 
point when an RM cell transmitted from the source end terminal 

20 is returned by the destination end terminal and received by 
the source end. Consequently, a prompt bandwidth control 
according to a change in the state of the traffic cannot be 
performed, so that the unused bandwidth of the transmission 
line cannot be always effectively used. 

25 An object of the invention is to provide an ATM 
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communication apparatus capable of preventing occurrence of 
congestion by guaranteeing a minimum cell rate to each of 
connections and allocating an unused bandwidth to each of the 
connections in accordance with fluctuations in traffic, 
5 Another object of the invention is to provide an ATM cell 

forwarding control method capable of effectively utilizing 
a bandwidth of each transmission line in an ATM network by 
dynamically controlling a transfer bandwidth of each 
connection within a predetermined bandwidth range. 

10 In order to achieve the objects, according to the 

invention, an ATM communication apparatus which is connected 
to a plurality of input lines and a plurality of output lines 
and transmits a cell received from each of the input lines 
to one of the plurality of output lines, which is specified 

15 by connection identification information included in a header 
of each of the received cells, has (a) a buffer memory for 
temporarily storing cells received from each of the input lines , 
(b) a write control unit for writing the cells received from 
each of the input lines into the buffer memory so that cells 

20 stored in the buffer memory form cell queues corresponding 
to connections for each output line, (c) a read control unit 
for reading out cells from each of cell queues formed in the 
buffer memory while guaranteeing a minimum cell rate 
predetermined for each connection within a range not exceeding 

25 a predetermined peak cell rate, and (d) means for adding 
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congestion indication to a cell read out from a cell queue 
of which stored cell amount exceeds a preset threshold. 

The read control unit is characterized by having, for 
example, (cl) a guaranteed bandwidth table in which information 
5 for allocating time slots to each of a plurality of connections 
multiplexed on the output line while guaranteeing a minimum 
cell rate is stored for each of the output lines, (c2) a shared 
bandwidth table in which information indicative of an 
allocation range of idle time slots allowed to each of the 

10 connections multiplexed is stored for each of the output lines , 
and (c3) means for determining a connection for which a cell 
is to be read out by referring to the shared bandwidth table, 
in a time slot which enters an idle state since there is no 
cell to be transmitted in a cell queue in a connection designated 

16 by the guaranteed bandwidth table and an idle time slot to 
which a connection is not designated in the guaranteed bandwidth 
table . 

According to the invention , an ATM cell forwarding control 
method in an ATM network including a plurality of nodes each 

20 connected to a plurality of input lines and a plurality of 
output lines, comprises: a step of writing ATM cells received 
from each of the input lines into a buffer memory so that stored 
cells form cell queues corresponding to connections for each 
output line at any of the nodes; and a step of, at the ATM 

25 node, reading out ATM cells from each of cell queues formed 
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in the buffer memory while guaranteeing a minimum cell rate 
predetermined for each connection and controlling a rate so 
as not to exceed a predetermined peakcell rate, and transmitting 
each of the ATM cells to an output line corresponding to a 
5 connection after adding congestion indication to a cell which 
is read out from a cell queue of which stored cell amount exceeds 
a preset threshold. 

According to the invention, before an ATM node actually 
enters a congestion state, congestion indication is added to 

10 a cell read out from a cell queue. A destination end system 
of the ATM cell added with the congestion indication transmits 
a control cell (RMcell) indicative of occurrence of congestion 
to a source end system of the received ATM cell. The ATM cell 
transmission amount is suppressed by the source end system 

15 which has received the control cell. In such a manner, the 
occurrence of congestion at the ATM node can be prevented. 

The other objects and features of the invention will 
become apparent from the following description of the 
embodiments with reference to the accompanying drawings. 

20 

BRIEF DESCRIPTION OF THE DRAWINGS 
Fig. 1 is a block diagram showing an ATM communication 
apparatus according to an embodiment of the invention. 

Fig. 2 is a diagram showing the format of an ATM cell. 
25 Fig. 3 is a flowchart showing operations of a write control 
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unit 13 illustrated in Fig. 1. 

Fig. 4 is a diagram showing an example of a queue management 
table 15 illustrated in Fig. 1. 

Fig. 5 is a diagram for explaining a logical cell queue 
5 formed in a buffer memory 11 illustrated in Fig. 1. 

Fig. 6 is a diagram showing an example of a definition 
table related to a plurality of connections multiplexed on 
the same line. 

Fig. 7 is a diagram showing an example of the configuration 
10 of a guaranteed bandwidth table 18 illustrated in Fig. 1. 

Fig. 8 is a diagram showing another example of the 
configuration of the guaranteed bandwidth table 18. 

Fig. 9A is a diagram showing an example of the 
configuration of a shared bandwidth table 19 illustrated in 
15 Fig. 1. 

Fig. 9B is a diagram showing a change in the contents 
of the shared bandwidth table 19 in association with 
transmission of a cell. 

Fig. 10 is a diagram schematically showing a connection 
20 allocating function to an empty time slot of an output connection 
selection unit 200 illustrated in Fig. 1. 

Fig. 11 is a flowchart showing operations of a read control 
unit 17 illustrated in Fig. 1. 

Fig. 12 is a flowchart showing operations of the output 
25 connection selection unit 200. 
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Fig. 13 is a diagram showing a control procedure for 
avoiding congestion in the invention. 

Fig, 14 is a diagram showing the cell format of an RM 

cell . 

5 

DESCRIPTION OF THE PREFERRED EMBODIMENTS 
Embodiments of the invention will be described 
hereinafter with reference to the drawings. 

Fig. 1 shows an ATM switch connected to a plurality of 
10 input lines (input highways) IN-i (i = 1 to n) and a plurality 
of output lines (output highways) OUT-i ( i = 1 to n) as an 
embodiment of an ATM communication system to which the invention 
is applied. 

As shown in Fig. 2, an ATM cell 50 to be supplied to each 
15 of the input lines IN-i is comprised of a cell header 51 of 
five bytes and a payload (information field) 52 of 48 bytes. 
The cell header 51 includes VPI/VCI as a connection identifier, 
a payload type PT of three bits, cell loss priority CLP of 
one bit, and header error control HEC. When the three bits 
20 of the payload type PT are designated by reference characters 
A, B, and C, a bit A indicates whether the cell is a user cell 
or a cell for management, a bit B indicates presence or absence 
of congestion, and a bit C indicates a segment type display 
bit for discriminating continuation or end of a frame (packet) . 
25 The header information of the ATM cell 50 supplied from 
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each of the input line IN-i is rewritten by an input processing 
unit 10 including a plurality of input line interfaces 
corresponding to the input lines. After that, the resultant 
ATM cell is supplied to a cell buffer area llA in a buffer 
memory 11 via a signal line 51. The rewriting of the header 
information includes rewriting of the connection identifier 
(VPI/VCI) and addition of an internal header including the 
number "p" of an output line (or output port) from which the 
input cell is to be transmitted. 

Prior to the transmission of the input cell to the signal 
line 51, the input processing unit 10 notifies a write control 
unit 13 of the output line number "p" of the input cell, and 
the connection identifier and the segment type which are 
extracted from the cell header via signal lines 52A, 52B, and 
52C, respectively. The write control unit 13 and the input 
processing unit 10 operate synchronously with a control clock 
WCK indicative of a write cycle. 

The write control unit 13 has : an address management table 
13T in which pointer addresses are stored in correspondence 
with identifiers of connections multiplexed on each of output 
lines for each output line number ; and a queue management table 
15 in which queue management information is stored in 
correspondence with the connection identifiers for each output 
line number. In each of the write cycles, the write control 
unit 13 executes a write control operation according to the 
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flowchart shown in Fig. 3. 

Specifically, when the output line number "p", the 
connection identifier, and the segment type of the input cell 
are received from the signal lines 52A to 52C (step 131) , the 
5 write control unit 13 reads out queue management information 
having the connection identifier from a queue connection table 
15-p corresponding to the output line number "p" (step 132) . 

In the queue management table 15-p, as shown in Fig. 4, 
a plurality of queue management information entries are stored . 

10 Each of the entries indicates in correspondence with the 
identifiers (VPI/VCI) 151 of the connections multiplexed on 
the output line of the line number "p" , length 152 of a cell 
queue (the number of stored cells) formed in the buffer memory 
11, a threshold 153 for suppressing cell transmission, and 

15 a discard indication flag 154 which indicates whether a 
preceding cell belonging to the same packet as the received 
cell has been discarded or not . The threshold 153 is determined 
for example, according to a value of the peak cell rate of 
each connection. 

20 The write control unit 13 determines whether or not the 

received cell (hereinafter, called an EOP cell) is a cell 
including a final segment of one packet from the segment type 
received from the signal line 52C (step 133). When the rece ived 
cell is a cell (first cell or intermediate cell) other than 

25 the EOP cell, the write control unit 13 determines whether 
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the cell buffer area 1 lA in the buffer memory 11 is inan over f I ow 
state or not (step 134) . When YES , the discard indication flag 
154 of the corresponding entry in the queue management table 
15-p is changed to the state "1" indicative of occurrence of 
5 the cell discarding (step 135) and the write cycle is finished 
without writing the received cell into the buffer memory 11. 

Whether the cell buffer area llA is in the overflow state 
or not can be determined by the number of idle addresses 
remaining in an idle address memory 14. If the cell buffer 

10 area llA is not in an overflow state, the discard indication 
flag 154 of the corresponding entry in the queue management 
information is checked (step 136) . When the discard flag is 
"1", that is, when at least one of preceding cells has been 
discarded, the write cycle is finished without writing the 

15 received cell into the buffer memory 11. 

When the discard indication flag is "0" in step 136 or 
when it is determined in step 133 that the received cell is 
an EOP cell, the write control unit 13 reads out a pointer 
address corresponding to the connection identifier from a write 

20 address management table 13T-p corresponding to the output 
line number "p" (step 140) and outputs the pointer address 
to a signal line 53. 

The pointer address is given as a write address WA to 
the buffer memory 11 , thereby writing the received cell , which 

25 was outputted from the input processing unit 10 to the signal 
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line 51, into a memory location of the address WA in the cell 
buffer area llA. The memory address taken out from the idle 
address memory 14 to a signal line 54 is written into a memory 
location of the address WA in a pointer area IIB of the buffer 
5 memory 11 as a pointer address to be paired with the received 
cell ( step 141 ) . 

The memory address taken out to the signal line 54 is 
stored into the write address management table 13T-p as a next 
pointer address with which the pointer address used as the 

10 write address WA by the write control unit 13 this time is 
replaced (step 142) . When an ATM cell having the same 
connection identifier is supplied next time with the same output 
line number "p" , by using the next pointer address as the write 
address WA, the received cell is written into the cell buffer 

16 area. By this operations, a series of ATM cells having the 
same connection identifiers are sequentially linked by the 
pointer addresses and a number of logical cell queues are formed 
for each output line in the buffer memory 11. 

The write control unit 13 increments the number 152 of 

20 cells in the entry in the queue management table 15-p and sets 
the discard indication flag 155 to "0" (step 143) , and updates 
a queue flag table 16 (step 144) in association with the writing 
of the ATM cell to the buffer memory 11. 

The queue flag table 16 is, as will be described by 

25 referring to Fig. 9, to indicate the presence or absence of 
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a stored cell by the flag bit "1" or "0" with respect to a 
plurality of connections multiplexed on the same output line. 
In a manner similar to the queue management table 15 , the queue 
flag table 15 is comprised of a plurality of tables 16-p {p 
5 = 1 to n) corresponding to the output line numbers. In the 
step 144, the bit corresponding to the connection identifier 
in the queue flag table 16-p corresponding to the output line 
number '^^p" of the received cell is set to "1". 

By the write control, as shown in Fig. 5, a logical cell 

10 queue 110-i corresponding to the connection identifier is 
formed in the buffer memory 11 . In the cell queue, for example , 
the remaining cells C16 and C17 in a packet PIO from which 
cells Cll to C15 as a part have been already outputted and 
cells C21 to C23 belonging to the next packet P20 are stored. 

15 If the buffer memory 11 enters the overflow state on receipt 
of a new cell C24 belonging to the packet P20, the cell C24 
is discarded. 

In the ATM communication apparatus of the invention , once 
discarding of a cell occurs, the subsequent cells C25 and C26 

20 belonging to the same packet P20 as the discarded cell C24 
are sequentially discarded irrespective of an unoccupied state 
of the buffer memory on receipt of the cells. An EOP cell C27 
of the discarded packet P20 and received cells of the following 
new packet are added to the cell queue 110-i. In this case, 

25 in a destination end system of the packet P20, the EOP cell 
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C27 is received after a while since the cell C23 which is stored 
in the cell queue before the discarding of cells occurs has 
been received. From the relation between the received cell 
C23 and the EOP cell C27 , the destination end system can 
5 recognize that a part of the packet P20 (the cells C24 to C26) 
has dropped out. In this case, the destination end system 
requests the source end system to retransmit the packet. 

The ATM cells and the pointer addresses stored in the 
buffer memory 11 are read out by a read control unit 17. The 
10 read control unit 17 has a read address management table 17T 
for storing a pointer address in correspondence with the 
connection identifier for each output line number, and is 
connected to an output connection selection unit 200 via signal 
lines 58 and 59 . 

15 The read control unit 17 counts control clocks RCK for 

indicating a read cycle which appears alternately with the 
write cycle, generates the output line number "^p" from which 
a cell is to be transmitted and a time slot number "s" on each 
of the output lines, and supplies the numbers "p" and "s" to 

20 the output connection selection unit 200 via the signal line 
58. As will be described hereinafter, the output connection 
selection unit 200 determines the identifier of a connection 
from which a cell is to be transmitted to the s-th time slot 
of the output line of the line number '^p" by referring to a 

25 guaranteed bandwidth table 18, a shared bandwidth table 19, 
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and a control information table 20, and outputs the connection 
identifier to the signal line 59 . 

When the connection identifier is received from the signal 
lint 59 , the read control unit 17 refers to the queue management 
5 information entry corresponding to the connection identifier 
from the queue management table 15-p corresponding to the output 
line number "p" , and determines whether the number 152 of stored 
cells (cell queue length) exceeds the threshold (TH) 153 or 
not . 

10 If the queue length exceeds the threshold (TH) 153, 

insertion of an EFCI (Explicit Forward Congestion Indication) 
bit is instructed to an output processing unit 12 via a signal 
line 56A and the pointer address is read out from the read 
address management table 17T on the basis of the output line 

15 number "p" and the connection identifier . The pointer address 
is given as a read address RA to the buffer memory 11 via a 
signal line 57, thereby reading out the ATM cell from the cell 
buffer area llA to a signal line 55A and simultaneously reading 
out the pointer address from the pointer area IIB to a signal 

20 line 55B. 

The read control unit 17 outputs the output line number 
"p" to a signal line 56B synchronously with the reading out 
of the ATM cell from the buffer memory 11 . The output processing 
unit 12 extracts the internal header from the ATM cell outputted 
25 to the signal line 55A and outputs the ATM cell to an output 
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line OUT-p indicated by the output line number "p". At this 
time, in the case where the insertion instruction signal of 
the EFCI bit has been received from a signal line 56A, the 
second bit (EFCI bit) in the payload type indication bits PT 
5 (three bits) included in the header of the ATM cell is set 
to the bit state "1" indicative of "congestion". After that, 
the resultant ATM cell is transmitted to the output line OUT~p. 

The pointer address read out from the pointer area IIB 
to the signal line 55B is stored into the read address management 

10 table 17T as the next pointer address with which the present 
pointer address used as the read address RA is replaced. The 
pointer address used as the read address RA is released to 
the idle address memory 14. 

The read control unit 17 decrements (by -1) the number 

15 152 of stored cells of the entry corresponding to the connection 
identifier in the queue management table 15-p corresponding 
to the output line number "p" each time an ATM cell is read 
out from the buffer memory 11. When the count value becomes 
zero, the bit corresponding to the connection identifier in 

20 the flag table 16-p is changed to "0". 

The output connection selection unit 200 determines the 
identifier of a connection from which a cell is tobe transmitted 
by referring to the queue flag table. 16 , a guaranteed bandwidth 
table 18 , a shared bandwidth table 19 , and a control information 

25 table 20 on the basis of the output line number ''^p" and the 
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time slot number ""^s" outputted. from the read control unit 17 
to the signal line 58, and outputs the identifier to the signal 
line 59. 

In a manner similar to the queue flag table 16, the 
5 guaranteed bandwidth table 18 is comprised of a plurality of 
tables 18-i (i = 1 to n) corresponding to output line numbers, 
the shared bandwidth table 19 is comprised of a plurality of 
tables 19-i (i = 1 to n) corresponding to output line numbers, 
and the control information table 20 is comprised of a plurality 

10 of tables 20-i (1 = 1 ton) corresponding to output line number s . 

A case of guaranteeing, for example, a bandwidth 
designated in a connection definition table 30-j shown in Fig. 
6 with respect to each of connections multiplexed on an output 
line OUT-j will now be examined. 

15 The connection definition table 30-j shows the relation 

among connection identifier 31 , peak cell rate (PGR) 32, minimum 
(or guaranteed) cell rate (mCR) 33, and shared bandwidth 34 
with respect to each of a plurality of connections multiplexed 
on an output line having line number (j) . 

20 The shared bandwidth 34 has a value (PGR - mCR) obtained 

by subtracting the minimum cell rate 33 from the peak cell 
rate 32. The connection identifier 31 is usually expressed 
by VPI /VCI . For simplicity of explanation , it is assumed here 
that five connections having the connection identifiers A, 

25 B, C, D, and E are multiplexed on the output line OUT-j. In 
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the following, the connections will be called connections A, 
B, C, D, and E. 

Fig. 7 shows the configuration of a guaranteed bandwidth 
table 18-j which is obtained on the basis of the connection 
5 definition table 30-j . 

The guaranteed bandwidth table 18~j indicates allocated 
time slots of each of the connections multiplexed on the output 
line OUT-j in an output bandwidth of a predetermined period 
on the output line OUT-j. In this case, the time slots are 

10 allocated at a weight ratio according to the minimum cell rate 
33 of each of the connections defined in the connection 
definition table 30-j . 

Assuming now that each time slot has the rate of O.lMbit/s 
on the output line OUT-j , an output bandwidth in the period 

15 of 30 time slots becomes 3 Mbit/s . In the connection definition 
table 30-j , the minimum cell rate of the connection A is 0.4 
Mbit/s. Consequently, four time slots are allocated on the 
connection definition table 30- j . Similarly , three time slots 
are allocated to the connection B having the minimum cell rate 

20 of 0.3 Mbit/s. 

The guaranteed bandwidth table 18-j consists of 30 entry 
areas for storing designated connections of 30 time slots 
corresponding to the output bandwidth of 3 Mbit/s. In Fig. 
7, the time slots are allocated so that the connections are 

25 arranged at cell intervals which are equal as much as possible 
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in accordance with the order from the connection having the 
highest minimum cell rate. In the example, first time slots 
of the connections A to D are allocated to continuous first 
to fifth time slots. Alternately, for example, as shown in 
5 Fig. 8, the first time slots of the connections A to D may 
be allocated apart from each other so that the allocated time 
slots are spread as much as possible. 

Fig. 9A shows an example of a shared bandwidth table 19-j 
corresponding to the output line OUT-j . 

10 The shared bandwidth table 19-j stores flag bit patterns 

19A to 19E corresponding to the connection IDs A to E, 
respectively. Each of the flag bit patterns is used to show 
the number of time slots corresponding to the shared bandwidth 
34 in the connection definition table 30-j and includes 

15 successive flag bit patterns of the number equal to the number 
of time slots. In the example, the bit length of the flag bit 
pattern is adjusted to the maximum value of the shared bandwidth 
34 . 

In the connection definition table 30-j , the connection 
20 B has the maximum value 0.5 Mbit/s of the shared bandwidth 
and the number of time slots is equal to five. Consequently, 
the flag bit pattern 19B of the connection B is "11111". 
Similarly , the connection A has thevalueofthe shared bandwidth 
of 0.4 Mbit/s and the number of time slots is equal to four. 
25 Consequently, the flag bit pattern 19A is "11110". 
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The flag bit pattern in the shared bandwidth table 19-j 
denotes the number of idle time slots that can be used by each 
of the connections. For example, when the connection B 
transmits a cell once by using an idle time slot, as shown 
5 in Fig. 9B, the bit pattern 19B is changed from "11111" to 
"11110". ' At the time point when the number of transmitting 
cells by using the idle time slots becomes five, the flag bit 
pattern of the connection B becomes "00000", and use of the 
idle time slots after that is inhibited. 
10 According to the embodiment, when the time slots 

guaranteed by the guaranteed bandwidth table 18-j and the idle 
time slots indicated by the flag bit pattern in the shared 
bandwidth table 19-j are maximally used , each of the connections 
transmits cells within the range of the peak cell rate 32 
15 indicated in the connection definition table 30-j . 

The flag bit pattern in the shared bandwidth table 19-j 
is initialized to the bit pattern shown in Fig. 9A at the time 
point when all the time slot positions in the guaranteed 
bandwidth table shown in Figs. 7 and 8 are used and the first 
20 time slot is to be allocated again. 

Fig. 10 is a diagram schematically showing the function 
of allocating connections to idle time slots of the output 
connection selection unit 200. 

When it is found that the s-th time slot of the output 
25 line number "p" designated by the read control unit 17 is in 
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an idle state , the output connection selection unit 200 obtains 
the AND of a bit pattern 190-p of a set of the first bits in 
the flag bit pattern group stored in the shared bandwidth table 
19-p corresponding to the output line number "p" and the bit 
5 pattern indicated by the flag table 16-p corresponding to the 
output line number "p". 

In this case, in the two bit patterns 190-p and 16-p, 
bits are arranged in accordance with the order of the connection 
identifiers so that the flag of the same connection is in the 

10 same bit position. The result of the AND operation therefore 
becomes a bit pattern 22 in which a transmission waiting 
connection which has the right of use of the idle time slot 
and has a cell stored in a cell queue in the buffer memory 
11 is indicated by the bit "1". 

15 A connection decision logic 23 decides a connection from 

which a cell is to be transmitted by the s-th time slot in 
the idle state on the basis of the bit pattern 22 obtained 
by the AND operation and highest priority connection 
designating information 20B stored in the control information 

20 table memory 20-p. The highest priority connection 

designating information is provided to avoid that an idle time 
slot (shared bandwidth) is consecutively allocated to the same 
connection. For example, the information indicates the bit 
position corresponding to a connection positioned subsequent 

25 to the previous connection to which the shared bandwidth is 
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allocated in the connection identifier arrangement. 

When a bit indicated by the highest priority connection 
designating information in the bit pattern 22 is "1", the 
connection decision logic 23 outputs a connection identifier 
5 corresponding to the bit to the signal line 59 and stores the 
next bit position as new highest priority connection 
designating information 20B into the memory 20-p. When the 
bit indicated by the highest priority connection designating 
information is "0", a decision is circularly made from the 

10 next bit in the bit pattern 22, a connection identifier 
corresponding to the bit "1" which is found first is outputted 
to the signal line 59, and the next bit position is stored 
as new highest priority connection designating information 
into the memory 20B. The bit position in the bit pattern 22 

15 is converted to a connection identifier with reference to 
connection identifier table (connection identifier 
arrangement information) 20A stored in the control information 
table 20-p. 

Fig. 11 shows the flow of control operations executed 
20 by the read control unit 17. 

The read control unit 17 increments the value of the 
parameter "p" indicative of the output port number 
synchronously with a control clock RCK (step 171) and compares 
the value of "p" with the maximum value Pmax of the output 
25 line number (step 172) . When the value of the parameter "p" 
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exceeds Pmax, the value of "p" is reset to the initial value 
of 1 (step 173) and increments the value of the parameter "s" 
indicative of the time slot number in the guaranteed bandwidth 
table 18 {step 174) . Subsequently, the value of the parameter 
5 "s" is compared with the maximum value Smax (step 175) . When 
the value of the parameter "s" exceeds Smax, the value is reset 
to the initial value (s = 1) (step 176) . 

The read control unit 17 supplies the values of the 
parameters "p" and "s" to the output connection selection unit 

10 200 to determine the output connection (step 200) . When the 
connection identifier of the output connection from which a 
cell is to be transmitted is determined, the queue management 
information corresponding to the connection identifier is read 
out from the queue management table 15-p corresponding to the 

15 output port number "p" (step 177) , and the state of the discard 
indication flag 154 and whether the number 152 of stored cells 
(cell queue length) exceeds the threshold 153 or not is 
determined (step 178) . The threshold 153 indicates, as shown 
by reference characters TH in Fig . 5 , the number of cells allowed 

20 to be stored in the cell queue 110-i of each connection formed 
in the cell buffer area llA in the buffer memory 11. 

In the embodiment, when the cell queue length 152 exceeds 
the threshold TH or when the discard indication flag is "1", 
the read control unit 17 determines that the cell transmission 

25 rate in the connection exceeds the allowable range and instructs 
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a cell source end system to suppress the transmission cell 
amount. The suppression of the transmission cell amount is 
achieved as follows. Insertion of the explicit forward 
congestion indication (EFCI) bit is instructed from the read 
5 control unit 17 to the output processing unit 12 via the signal 
line 56A (step 179) , the output processing unit 12 which has 
received the instruction changes the EFCI bit in the payload 
type (PT) field in the header of a user cell read out from 
the cell gueue 110-i to "1" , thereby notifying the destination 

10 end system of occurrence of congestion, and the destination 
end system returns the RM cell to the source end system. 

After instructing the insertion of the EFCI bit, the read 
control unit 17 taken out the read address RA corresponding 
to the connection identifier from the read address management 

15 table 17T-p corresponding to the output port number "p", and 
reads out the ATM cell and the pointer address from the buffer 
memory 11 in accordance with the read address RA (step 180) . 
When the connection from which a cell is to be transmitted 
does not exist, an idle cell is transmitted. 

20 After that, the read control unit 17 subtracts a value 

of one cell from the count value of the number 152 of stored 
cells corresponding to the connection identifier in the queue 
management table 15-p (step 181) . When the number of stored 
cells becomes zero (step 182) , the cell flag corresponding 

25 to the connection identifier in the flag table 16-p is changed 
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to "0" . 

Fig . 12 shows the flowchart of control operations executed 
by the output connection selection unit 200. 

On receipt of the parameters "p" and '"^ s " from the read 
5 control unit 17 , the output connection selection unit 200 first 
determines the value of the time slot number "s" (step 201) . 
At the time point when the time slot number "s" becomes the 
initial value (s = 1) , the flag bit in the shared bandwidth 
table 18-p corresponding to the output line number "p" is reset 
10 to an initial bit pattern (step 202) . 

The output connection selection unit 200 refers to the 
s-th time slot in the guaranteed bandwidth table 18-p 
corresponding to the output line number "p" (step 203) and 
determines the presence or absence of a designated connection. 
15 When there is a designated connection, the flag table 16-p 
corresponding to the output line number "p" is referred to 
(step 204) and the presence or absence of the stored cells 
in the designated connection is determined (step 205) . When 
there are stored cells in the designated connection, the 
20 designated connection is determined as a connection from which 
an ATM cell is to be read (step 207) . 

When there is no designated connection in the s-th time 
slot in the guaranteed bandwidth table 18-p or there is no 
stored cell in the designated connection, the AND of the flag 
25 bit patterns in the shared band width table 19-p and the flag 
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table 16-p corresponding to the output line number '^p" is 
calculated (step 210) . When the operation result is checked 
(step 211) and the value of the operation result is zero, it 
is decided that there is no output connection from which a 
5 cell is to be transmitted ( step 212 ) . When the opera tion result 
is not zero, an output connection is determined on the basis 
of the highest priority connection information from the bit 
pattern indicated by the operation result (step 213) and, after 
that, the highest priority connection information and the 
10 shared bandwidth flag pattern of the output connection are 
updated (steps 214 and 215) . 

The identifier of the output connection determined in 
step 207 or 213 or the selection result indicative of no output 
connection determined in step 212 is replied to the read control 
15 unit 17 via the signal line 59. 

Fig. 13 shows a control procedure of avoiding congestion 
according to the invention. 

Shown in the diagram are a source end system lA, a 
destination end system IB, an ATM switch 2 having the 
20 above-described configuration, and ATM cells 50-1 to 50-4 
transmitted from the source end system lA to the destination 
end system IB. 

When the amount of cells transmitted from the source end 
system lA increases and exceeds, for example, the peak cell 
25 rate (PGR) preliminarily declared, the amount of cells stored 
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in the cell queue corresponding to a connection between the 
systems lA and IB formed in the ATM switch 2 increases and 
the cell queue length exceeds the threshold TH. In the ATM 
switch 2 of the invention, when the cell queue length exceeds 
5 the threshold TH , irrespective whether the buffer memory 11 
actually enters a cell discarding state or not, by setting 
the EFCI bit in the cell read out from the cell queue to "1", 
it is notified to the destination end system IB that as if 
congestion occurs in the ATM switch 2, and the RM cells 60-1 

10 and 60-2 are returned from the destination end system IB to 
the source end system lA. 

The RM cell is comprised of, as shown in Fig. 14, in a 
manner similar to the user cell, a header 61 of five bytes 
and a payload 62 of 48 bytes. In the header 61 of the RM cell, 

15 for example, in the case of a virtual path, "6" is set in a 
virtual channel identifier (VCI) field, and "110" is set in 
a payload type identifier (PTI) field. In the case of the 
virtual connection, "110" is set in the PTI. 

The payload 62 starting from the sixth byte of the RM 

20 cell includes an RM protocol identifier in the sixth byte. 
In the seventh byte, the first to fifth bits are used as a 
reserved area which will be used in future, the sixth bit is 
set as a BN (Backward Notification) bit for backward congestion 
notification, the seventh bit is set as a CI (Congestion 

25 Indication) bit for indicating congestion, and the eighth bit 
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is set as a DIR (direction) bit indicative of the transfer 
direction of the RM cell. The eighth and ninth bytes in the 
RM cell are a reserved area. A current cell rate (CCR) is set 
in the 10th and 11th bytes. A minimum cell rate (mCR) is set 
5 in the 12th and 13th bytes. An explicit cell rate (ER) is set 
in the 14th and 15th bytes. The 16th to 51st bytes and the 
third to eighth bits in the 52nd byte are reserved areas to 
be used in future. A cyclic redundancy check (CRC) of payload 
information is set in the first and second bits in the 52nd 

10 byte and the 53rd byte. 

The destination end system IB which has received the user 
cell 50 including congestion indication from the ATM switch 
2 transmits an RM cell 60 in which each of the CI bit and the 
DIR bit is set to "1" to the source end system lA, thereby 

15 promoting suppression of the cell transmission amount. When 
the RM cell in which the CI bit is set to "1" is received, 
in order to avoid congestion in the ATM network, the source 
end system lA suppresses the transmission cell amount. The 
operation of suppressing the transmission cell amount is 

20 continued until it is confirmed that the transmission of the 
RM cell in which the CI bit is "1" is stopped. 

In the foregoing embodiment, a logical variable length 
cell queue linked by the pointer address is formed in the common 
buffer memory 11 in correspondence with each connection 

25 identifier, and the source end system is notified of the 
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connection in which the queue length exceeds the threshold 
TH to suppress the transmission cell amount, thereby avoiding 
occurrence of congestion. Even if cell discarding occurs due 
to insufficient capacity of the buffer memory, by discarding 
5 the subsequent cells belonging to the same packet of the 
discarded cell, the buffer memory and the line bandwidth are 
prevented from being used by useless cells. 

As another embodiment of the invention, it is also 
possible to preliminarily divide the buffer memory 11 into 

10 a plurality of buffer areas having fixed length, allocate the 
buffer area of the fixed length to_ each connection, and write 
and read out ATM cells to and from the buffer memory in an 
FIFO fashion by using the buffer area as a fixed length 
individual cell queue. 

15 In the fixed length individual cell queue, the address 

of a cell area from which an ATM cell is to be read out next 
is stored as a read address pointer RAP and the address of 
a cell area to which ATM cell is to be written next is stored 
as a write address pointer WAP for each queue . It is sufficient 

20 to circularly update the valued of the pointers RAP and WAP 
cell by cell each time an ATM cell is read out and written 
from and to the buffer memory. 

For example, in the ATM switch of Fig. 1, an identifier 
of a buffer area (cell queue) to be used and the pointers WAP 

25 and RAP are stored in correspondence with the connection 



31 



identifier in each queue management table 15 provided for each 
output line. On the basis of the output line number "p" of 
an input cell and the connection identifier, the write control 
unit 13 reads the queue identifier and the write address pointer 
5 WAP from the queue management table 15-p, writes the input 
cell to the cell area indicated by the pointer WAP in the buffer 
area indicated by the queue identifier and, after that, updates 
the address pointer WAP. On the other hand, the read control 
unit 17 reads the queue identifier and the read address pointer 

10 RAP from the queue management table 15-p on the basis of the 
output line number '"''p" and the connection number designated 
by the output connection selection unit 200 , reads out a cell 
from a cell area indicated by the pointer RAP in the buffer 
area indicated by the queue identifier and , after that , updates 

15 the read address pointer RAP. 

In the case of adopting the fixed length individual cell 
queue system, the write address management table 13T, the read 
address table 17T , and the pointer area IIB in the buffer memory 
are unnecessary. In the fixed length individual cell queue 

20 system, different from the shared buffer system, the number 
of cells which can be stored in each connection is limited 
(by the upper limit value) . Consequently, when the number of 
stored cells reaches the upper limit value at the time point 
of writing a cell, cell discarding occurs. 

25 The cell discarding can be avoided by setting the 



32 



threshold TH for setting the EFCI bit in the output cell to 
"1" to a value sufficiently lower than the upper limit value 
of the number of stored cells and suppressing the amount of 
cells transmitted from the source end system before the number 
5 of stored cells reaches the upper limit value. When a number 
of nodes are interposed between the source end system and the 
destination end system, however, the response to the cell 
suppressing control becomes delay. 

For example, in the case where the amount of allocating 

10 the unused bandwidth to each of the connections decreases due 
to an increase in traffic and the transfer rate in the ATM 
network decreases to a bandwidth close to the minimum cell 
rate, on the contrary, in the case where the source end system 
transmits cells at a rate higher than the peak cell rate, the 

15 amount of stored cells gradually increases in any of the nodes, 
and congestion indication is added to a cell read out from 
the cell queue whose number of stored cells exceeds the threshold 
TH. In this case, when a number of nodes are interposed between 
the source end system and the destination end system, cells 

20 are overflowed from the cell queue before the RM cell generated 
in the destination end system reaches the source end system, 
and there is the possibility that the cells are discarded. 
The possibility of discarding the cells can be reduced by setting 
the threshold TH at a lower value . When the shared buffer system 

25 in which the cell queue has a variable length is adopted, the 
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possibility of discarding cells can be further reduced. 

In the case of adopting the fixed length individual cell 
queue, it is desirable to indicate the storage location of 
the first cell of a packet being stored in each cell queue, 
5 for example, by a pointer HCP stored in the queue management 
table 15. In the case where the discarding of a cell occurs, 
by resetting the write address pointer WAP to the value of 
the HCP, preceding cells that belong to the same packet as 
the discarded cell and have been already stored can be discarded 

10 in a lump. In this case, by sequentially discarding the 
subsequent cells (including the EOP cell) of the packet, the 
cells can be discarded on the packet unit basis. 

When the first cell of the packet has been already read 
out from the cell queue and the pointer HCP has been cleared, 

15 by reading out the write address pointer WAP and resetting 
the write address pointer WAP to the value of the pointer RAP, 
all of the stored cells are discarded. In this case, it is 
sufficient to sequentially discard following cells and store 
the EOP cell in the discarded packet and a group of cells of 

20 the next packet received thereafter into a cell queue. 

As described above, by discarding new input cells as well 
as cells having been already stored in the buffer memory on 
the packet unit basis , congestion in the ATM node can be promptly 
solved. By stopping the transmission of the preceding cells 

25 that become now meaningless even if they are transferred because 
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some of the subsequent cells have been already discarded, the 
traffic of useless cells in the downstream area of the ATM 
network can be suppressed. 

As obviously understood from the above description, 
5 according to the invention, the ATM cell transfer guaranteeing 
the minimum cell rate of each connection and effectively 
utilizing the idle bandwidth in the transmission line within 
the range of the peak cell rate of each connection is performed. 
Thus, the throughput of cells at an ATM node is improved and, 

10 as a result, the necessary capacity of the buffer memory per 
connection can be reduced. 

Further, according to the invention, when the amount of 
stored cells in the buffer memory exceeds the threshold preset 
for each connection, the control operation for suppressing 

15 the amount of cells transmitted from the source end system 
is started. Consequently, an increase in amount of stored 
cells in the buffer memory can be suppressed and the occurrence 
of discarding of cells can be prevented. According to the 
invention , even if the discarding of cells occurs , by discarding 

20 the subsequent cells belonging to the same packet as the 
discarded cell and, if it is possible, also discarding already 
stored preceding cells which belong to the same packet as the 
discarded cell, the congestion state is promptly solved and 
the ATM network resources can be effectively used. 

25 



